<template>
  <div class="wrapper">
    <!-- 卡片组件 -->
    <card :_Title="i18nText('order.myOrder', '我的订单')" :_Size="16" :_Tabs="changeWay" @_Change="change"
          v-if="!homePage"></card>
    <card :_Title="i18nText('order.myOrder', '我的订单')" :_Size="16" :_Tabs="changeWay" @_Change="change"
          :_More="i18nText('order.allOrders', '全部订单')" _Src="/home/MyOrder" v-else></card>
    <!-- 搜索 筛选 -->
    <div class="mb_24 box" v-if="!homePage">
      <div class="global_float_right">
        <Input
          class="width_300"
          search
          enter-button
          v-model="params.keywords"
          @on-search="getList"
          :placeholder="i18nText('order.searchByOrderID', '请输入订单号搜索')"
        />
      </div>
    </div>
    <!-- 订单列表 -->
    <empty v-if="orderList.length === 0"/>
    <div class="order-content" v-else>
      <div
        class="order-list"
        v-for="(order, onderIndex) in orderList"
        :key="onderIndex"
      >
        <div class="order-header">
          <div>
            <div>{{ filterOrderStatus(order.orderStatus) }}</div>
            <div>
              {{ i18nText('order.orderID', '订单号') }}：{{ order.sn }} &nbsp; &nbsp; &nbsp;{{ order.createTime }}
            </div>
          </div>
          <div>
            <Button v-if="order.orderStatus === 'COMPLETED'" @click="delOrder(order.sn)"
                    class="del-btn mr_10 fontsize_16" style="margin-top:-5px;" type="text" icon="ios-trash-outline"
                    size="small"></Button>
            <span>{{ order.flowPrice | unitPrice(i18nText('symbol.currencySymbol', '￥')) }}</span>
          </div>
        </div>
        <div class="order-body">
          <div class="goods-list">
            <div
              v-for="(goods, goodsIndex) in order.orderItems"
              :key="goodsIndex"
            >
              <img
                @click="goodsDetail(goods.skuId, goods.goodsId)"
                class="hover-color"
                :src="goods.image"
                alt=""
              />
              <div>
                <div class="hover-color" @click="goodsDetail(goods.skuId, goods.goodsId)">{{ goods.name }}</div>
                <div class="mt_10">
                  <span class="global_color"
                  >{{ goods.goodsPrice | unitPrice(i18nText('symbol.currencySymbol', '￥')) }} </span
                  >x {{ goods.num }}
                </div>
                <Button v-if="goods.commentStatus == 'UNFINISHED'" @click="comment(order.sn, goodsIndex)" size="small"
                        type="success" class="fontsize_12"
                        style="position:relative;top:-22px;left:100px;margin-right:10px">{{ i18nText('review.writeReview', '评价') }}
                </Button>
                <Button v-if="goods.complainStatus == 'NO_APPLY'" @click="complain(order.sn, goodsIndex)" type="warning"
                        class="fontsize_12" size="small" style="position:relative;top:-22px;left:100px">
                  {{ i18nText('order.complaint', '投诉') }}
                </Button>
              </div>
            </div>
          </div>
          <div>
            <!--            <span @click="shopPage(order.storeId)">{{ order.storeName }}</span>-->
          </div>
          <div>
            <!-- 订单基础操作 -->
            <Button @click="orderDetail(order.sn)" type="info" size="small">{{ i18nText('order.orderDetails', '订单详情') }}</Button>
            <Button @click="handleCancelOrder(order.sn)" type="error" v-if="order.allowOperationVO.cancel" size="small">
              {{ i18nText('order.cancelOrder', '取消订单') }}
            </Button>
            <Button @click="goPay(order.sn)" size="small" type="success" v-if="order.allowOperationVO.pay">{{ i18nText('order.payNow', '去支付') }}</Button>
            <Button @click="received(order.sn)" size="small" type="warning" v-if="order.allowOperationVO.rog">{{ i18nText('order.confirmReceipt', '确认收货') }}
            </Button>
            <!-- 售后 -->
            <Button
              v-if="order.groupAfterSaleStatus && (order.groupAfterSaleStatus==='NOT_APPLIED'|| order.groupAfterSaleStatus==='PART_AFTER_SALE' )"
              @click="applyAfterSale(order.orderItems)" size="small">{{ i18nText('order.applyForAfterSalesService', '申请售后') }}
            </Button>
          </div>
        </div>
      </div>
      <Spin size="large" fix v-if="spinShow"></Spin>
    </div>
    <!-- 分页 -->
    <div class="page-size" v-if="!homePage">
      <Page :total="total" @on-change="changePageNum"
            @on-page-size-change="changePageSize"
            :page-size="params.pageSize"
            show-total
            show-sizer>
      </Page>
    </div>
    <!-- 选择售后商品 -->
    <Modal v-model="afterSaleModal" :title="i18nText('afterSaleOrder.selectProductApplyService', '请选择申请售后的商品')">
      <div>
        <Table
          border
          :columns="afterSaleColumns"
          :data="afterSaleArr"
          @on-row-click="afterSaleSelect"
        >
        </Table>
      </div>
      <div slot="footer"></div>
    </Modal>
    <Modal v-model="cancelAvail" :title="i18nText('order.selectReasonForCancelingOrder', '请选择取消订单原因')" @on-ok="sureCancel" @on-cancel="cancelAvail = false">
      <RadioGroup v-model="cancelParams.reason" vertical type="button" button-style="solid">
        <Radio :label="item.reason" v-for="item in cancelReason" :key="item.id">
          {{ item.reason }}
        </Radio>
      </RadioGroup>
    </Modal>
  </div>
</template>

<script>
import {getOrderList, sureReceived, cancelOrder, delOrder} from '@/api/order';
import {afterSaleReason} from '@/api/member';
import {orderStatusList} from '../enumeration.js'
import { i18nText } from '@/utils/i18n'

export default {
  name: 'MyOrder',
  props: {
    homePage: { // 判断是否个人中心首页展示内容
      type: Boolean,
      default: false
    }
  },
  data() {
    return {
      orderList: [], // 订单列表
      params: { // 请求参数
        pageNumber: 1,
        pageSize: 10,
        // orderStatus: 'ALL',
        keywords: '',
        tag: 'ALL'
      },
      cancelParams: { // 取消售后参数
        orderSn: '',
        reason: ''
      },
      // 状态数组
      orderStatusList,
      changeWay: [ i18nText('order.allOrders', '全部订单'), i18nText('order.pendingPayment', '待付款'),
        i18nText('order.pendingDelivery', '待收货'), i18nText('order.status.completed', '已完成')], // 订单状态
      total: 0, // 数据总数
      spinShow: false, // 加载状态
      afterSaleModal: false, // 选择售后商品模态框
      afterSaleColumns: [ // 售后商品表头
        {title: i18nText('product.productName', '商品名称'), key: 'name'},
        {title: i18nText('product.price', '价格'), key: 'goodsPrice'}
      ],
      afterSaleArr: [], // 售后商品列表
      cancelAvail: false, // 取消订单modal控制
      cancelReason: [] // 取消订单原因
    };
  },
  mounted() {
    if (this.homePage) this.params.pageSize = 5;
    this.getList();
  },
  methods: {
    goodsDetail(skuId, goodsId) {
      // 跳转商品详情
      let routeUrl = this.$router.resolve({
        path: '/goodsDetail',
        query: {skuId, goodsId}
      });
      window.open(routeUrl.href, '_blank');
    },
    // 切换订单状态
    change(index) {
      switch (index) {
        case 0:
          this.params.tag = 'ALL'
          break;
        case 1:
          this.params.tag = 'WAIT_PAY'
          break;
        case 2:
          this.params.tag = 'WAIT_ROG'
          break;
        case 3:
          this.params.tag = 'COMPLETE'
          break;
      }
      this.getList()
    },
    // 跳转店铺首页
    shopPage(id) {
      let routeUrl = this.$router.resolve({
        path: '/Merchant',
        query: {id: id}
      });
      window.open(routeUrl.href, '_blank');
    },
    orderDetail(sn) {
      // 跳转订单详情
      this.$router.push({name: 'OrderDetail', query: {sn}});
    },
    received(sn) { // 确认收货
      sureReceived(sn).then(res => {
        if (res.success) {
          this.$Message.success(i18nText('order.successfullyConfirmedReceiptOfGoods', '确认收货成功'))
          this.getList()
        }
      })
    },
    goPay(sn) { // 去支付
      this.$router.push({path: '/payment', query: {orderType: 'ORDER', sn}});
    },
    applyAfterSale(goodsItem) { // 申请售后
      let arr = []
      goodsItem.forEach(e => {
        if (e.afterSaleStatus === 'NOT_APPLIED' || e.afterSaleStatus === 'PART_AFTER_SALE') {
          arr.push(e)
        }
      });
      if (arr.length === 1) {
        this.$router.push({name: 'ApplyAfterSale', query: {sn: arr[0].sn}})
      } else {
        this.afterSaleArr = arr;
        this.afterSaleModal = true
      }
    },
    // 申请售后
    afterSaleSelect(item) {
      this.$router.push({name: 'ApplyAfterSale', query: {sn: item.sn}})
    },
    comment(sn, goodsIndex) { // 评价
      this.$router.push({path: '/home/addEval', query: {sn, index: goodsIndex}})
    },
    complain(sn, goodsIndex) { // 投诉
      this.$router.push({name: 'Complain', query: {sn, index: goodsIndex}})
    },
    delOrder(sn) { // 删除订单
      this.$Modal.confirm({
        title: i18nText('order.deleteOrder', '删除订单'),
        content: '<p>' + i18nText('order.sureDeleteCurrentOrder', '确认删除当前订单吗？') + '</p>',
        onOk: () => {
          delOrder(sn).then(res => {
            if (res.success) {
              this.$Message.success(i18nText('common.deleted', '删除成功'));
              this.getList()
            }
          })
        },
        onCancel: () => {
        }
      });
    },
    getList() { // 获取订单列表
      this.spinShow = true;
      let params = JSON.parse(JSON.stringify(this.params))
      if (params.orderStatus === 'ALL') {
        delete params.orderStatus
      }
      getOrderList(params).then(res => {
        this.spinShow = false
        if (res.success) {
          this.orderList = res.result.records;
          this.total = res.result.total;
        }
      });
    },
    changePageNum(val) { // 修改页码
      this.params.pageNumber = val;
      this.getList()
    },
    changePageSize(val) { // 修改页数
      this.params.pageNumber = 1;
      this.params.pageSize = val;
      this.getList()
    },
    handleCancelOrder(sn) {
      // 取消订单
      this.cancelParams.orderSn = sn;
      afterSaleReason('CANCEL').then(res => {
        if (res.success) {
          this.cancelReason = res.result;
          this.cancelAvail = true
          this.cancelParams.reason = this.cancelReason[0].reason
        }
      })
    },
    sureCancel() { // 确定取消
      cancelOrder(this.cancelParams).then(res => {
        if (res.success) {
          this.$Message.success(i18nText('order.successfullyCanceledAnOrder', '取消订单成功'))
          this.getList()
          this.cancelAvail = false
        }
      })
    },
    filterOrderStatus(status) { // 获取订单状态中文
      const ob = this.orderStatusList.filter(e => {
        return e.status === status
      });
      return ob && ob[0] ? ob[0].name : status
    }
  }
};
</script>

<style scoped lang="scss">
.wrapper {
  margin-bottom: 40px;
}

.box {
  overflow: hidden;
}

.page-size {
  margin: 15px 0px;
  text-align: right;
}

/** 订单列表 */
.order-list {
  border: 1px solid #ddd;
  border-radius: 3px;
  margin-bottom: 10px;

  &:hover {
    .del-btn {
      visibility: visible;
    }
  }

  .del-btn {
    visibility: hidden;
  }

  .order-header {
    display: flex;
    align-items: center;
    padding: 10px;
    justify-content: space-between;
    border-bottom: 1px solid #ddd;

    > div:nth-child(1) > div:nth-child(2) {
      font-size: 12px;
      color: #999;
      margin-top: 3px;
    }
  }

  .order-body {
    display: flex;
    justify-content: space-between;
    color: #999;
    padding: 10px;

    .goods-list > div {
      width: 500px;
      display: flex;
      margin-bottom: 10px;

      img {
        width: 60px;
        height: 60px;
        margin-right: 10px;
      }

      > div {
        flex: 1;
      }
    }

    > div:nth-child(2) {
      width: 130px;
      text-align: center;

      span {
        color: #438cde;
        cursor: pointer;

        &:hover {
          color: $theme_color;
        }
      }

      .ivu-icon {
        color: #ff8f23;
        cursor: pointer;

        &:hover {
          color: $theme_color;
        }
      }
    }

    > div:nth-child(3) {
      width: 170px;
      text-align: right;

      .ivu-btn {
        margin-bottom: 10px;
      }
    }
  }
}
</style>
